## **EECE 3324**

### Summer 2022

# Assignment 2

Implement a pipelined ALU by putting registers around your ALU as shown below. Your design needs to run at a 40 MHz clock rate (a full clock cycle is 25 nsec. and a half cycle is 12.5 nsec.). Your circuit should be connected as shown in Figure 1.



Figure 1. Block Diagram

Your design should have the terminals shown in Figure 2a, b are 32 bit input busses



Figure 2. CPU Terminals

The ALU has already been designed in Assignment 1 to provide outputs in less than 20nsec. It is acceptable for all of the registers to remain undefined until something is clocked into them.

1

**Before you start designing the hardware** as shown in Figure 1 using Verilog, fill out the table below and find the value of the wires and output ports at each clock cycle. The purpose of filling out the table is to check your basic understanding of the hardware. If you believe the output is undefined, then use Xs to denote it, for example 32'hxxxxxxxx.

You must use a software such as Microsoft Word or Microsoft Excel to fill out the table. Using your own handwriting will not earn you any points.

Submit this table as part of your final submission to Canvas.

| Clock Status | abus         | bbus          | ALUinputA | ALUinputB | ALUoutput | S      | Cin | dbus |
|--------------|--------------|---------------|-----------|-----------|-----------|--------|-----|------|
| clk = 0      | 32'h00000000 | 32'h00000000  |           |           |           | 3'b100 | 0   |      |
| <u> </u>     | 32'h00000000 | 32'h00000000  |           |           |           | 3'b100 | 0   |      |
| clk = 1      | 32'h00000000 | 32'h000000000 |           |           |           | 3'b100 | 0   |      |
| clk = 0      | 32'h00000000 | 32'h00000000  |           |           |           | 3'b100 | 0   |      |
| <b>↑</b>     | 32'h00000000 | 32'h00000000  |           |           |           | 3'b100 | 0   |      |
| clk = 1      | 32'h00000000 | 32'h00000000  |           |           |           | 3'b100 | 0   |      |
| clk = 0      | 32'hFFFFFFF  | 32'h00000000  |           |           |           | 3'b010 | 0   |      |
| <b>↑</b>     | 32'hFFFFFFF  | 32'h00000000  |           |           |           | 3'b100 | 0   |      |
| clk = 1      | 32'hFFFFFFF  | 32'h00000000  |           |           |           | 3'b100 | 0   |      |
| clk = 0      | 32'hFFFFFFF  | 32'h00000000  |           |           |           | 3'b010 | 1   |      |
| <b>↑</b>     | 32'hFFFFFFF  | 32'h00000000  |           |           |           | 3'b100 | 1   |      |
| clk = 1      | 32'hFFFFFFF  | 32'h00000000  |           |           |           | 3'b100 | 1   |      |
| clk = 0      | 32'h7FFFFFF  | 32'h00000000  |           |           |           | 3'b010 | 0   |      |
| <u></u>      | 32'h7FFFFFF  | 32'h00000000  |           |           |           | 3'b010 | 0   |      |
| clk = 1      | 32'h7FFFFFFF | 32'h00000000  |           |           |           | 3'b010 | 0   |      |

Table 1. Alupipe Table

A Verilog testbench file to provide inputs to your design will be provided by your course instructor. A similar file may be used to grade your design. Your highest-level Verilog file needs to be named **alupipe.v** to be compatible with the testbench file.

<u>Create your own the testbench file</u> that fully tests your design with at least 32 test scenarios. You must provide comments on your testbench file so that others can follow your work. You will post your testbench to Assignment 2 Discussion on Canvas. Your classmates will review your testbench and provide feedback about it. Your classmates will also grade/rate your testbench file.

Please submit all your Verilog files including your new testbench file to Assignment 2 Link on Canvas. For your initial post to Assignment 2 Discussion, you only need to post your new testbench file.

#### **Rules of Engagement:**

- 1. You are only allowed to complete this assignment individually/as a group as assigned by the course instructor.
- 2. You are NOT allowed to work/collaborate/show your work to other people.
- 3. Your work must be your own. Should you be found guilty of using someone else's work (either full or partly), an "F" will be assigned as your overall course grade for the semester.
- 4. Read, understand, and follow NU Honor Code.
- 5. After you have completed your work, you must submit all your files to Canvas. Once you have submitted all your code to Canvas, you then need to be live interviewed by your TA/course instructor to verify all your work for this assignment using Xilinx Vivado. Failure to demonstrate your work to your grader or course instructor will result in a zero as the final grade of this assignment.
- 6. All work must be done using Xilinx Vivado software. Failure to do this will result in a zero as the final grade of this assignment.
- 7. **The use of \* (star symbol) in Verilog is strictly prohibited**. Using a \* (star symbol) will result in a zero as the final grade of this assignment.

#### **Lab Submission:**

You must show a live <u>working demo</u> to your course instructor or grader to receive a grade. The demo must be completed individually/as a group as instructed by the course instructor. Questions will be asked during the demo. Points will be deducted from your Lab grade should you fail to answer any questions. Comments such as "I cannot remember why I did that" will not help you. Come prepared.

Upload all the Verilog files used and the improved test bench file to Canvas. <u>Make sure that your Verilog files (including the test bench file)</u> are heavily commented as it is part of the grading. Your work will also be judged by the complexity of your modified test bench file. The more complex and rigorous your test bench file in testing different scenarios, the more points you earn.

#### Do not zip all your files together.

An automatic zero will be assigned for anyone who fails to show a live working demo to your course instructor or grader.